<template>
  <view class="viewport">
    <view class="logo">
      <image src="https://big-project-tree.oss-cn-beijing.aliyuncs.com/userAvatar/b757f48d05bc4e371c93705d6954b345.png">
</image>
    </view>
    <view class="login">
      <!-- #ifdef MP-WEIXIN -->
      <button class="button phone" @tap="onWxLogin">
        <text class="icon icon-phone"></text>
        微信一键登录
      </button>
      <!-- #endif -->
      <view class="tips">登录/注册即视为你同意《服务条款》和《绿色方舟隐私协议》</view>
    </view>
  </view>
</template>

<script setup>
import { ref } from 'vue'
import { onLoad } from '@dcloudio/uni-app'
import { postLoginWxMinAPI } from '@/services/login'
import { userStore } from '@/stores/UserStore'
const memberStore = userStore()
const code = ref('')
onLoad(async () => {
  // 获取登录凭证Code
  const result = await wx.login()
  code.value = result.code
})

// 微信登录
const onWxLogin = async () => {
  if (!code.value) {
    uni.showToast({ title: '未获取到code', icon: 'none' })
    return
  }
  console.log("code", code.value)
  const res = await postLoginWxMinAPI({
    code: code.value
  })

  console.log("登录结果", res.data)
  if (res && res.code === 1) {
    // 登录成功，保存用户信息
    memberStore.setUser(res.data)
    /*  uni.setStorageSync('userInfo', res.data) */
    uni.showToast({ title: '登录成功', icon: 'success' })
    // 跳转到首页
    setTimeout(() => {
      //uni.switchTab({ url: '/pages/index/index' })
      uni.navigateBack()
    }, 500)
  } else {
    uni.showToast({ title: res.data.msg || '登录失败', icon: 'none' })
  }
}
</script>

<style lang="scss">
page {
  height: 100%;
}

.viewport {
  display: flex;
  flex-direction: column;
  height: 100%;
  padding: 20rpx 40rpx;
}

.logo {
  flex: 1;
  text-align: center;

  image {
    width: 220rpx;
    height: 220rpx;
    margin-top: 15vh;
  }
}

.login {
  display: flex;
  flex-direction: column;
  height: 60vh;
  padding: 40rpx 20rpx 20rpx;

  .input {
    width: 100%;
    height: 80rpx;
    font-size: 28rpx;
    border-radius: 72rpx;
    border: 1px solid #ddd;
    padding-left: 30rpx;
    margin-bottom: 20rpx;
  }

  .button {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 80rpx;
    font-size: 28rpx;
    border-radius: 72rpx;
    color: #fff;

    .icon {
      font-size: 40rpx;
      margin-right: 6rpx;
    }
  }

  .phone {
    background-color: #28bb9c;
  }

  .wechat {
    background-color: #06c05f;
  }

  .extra {
    flex: 1;
    padding: 70rpx 70rpx 0;

    .caption {
      width: 440rpx;
      line-height: 1;
      border-top: 1rpx solid #ddd;
      font-size: 26rpx;
      color: #999;
      position: relative;

      text {
        transform: translate(-40%);
        background-color: #fff;
        position: absolute;
        top: -12rpx;
        left: 50%;
      }
    }

    .options {
      display: flex;
      justify-content: center;
      align-items: center;
      margin-top: 70rpx;

      button {
        padding: 0;
        background-color: transparent;

        &::after {
          border: none;
        }
      }
    }

    .icon {
      font-size: 24rpx;
      color: #444;
      display: flex;
      flex-direction: column;
      align-items: center;

      &::before {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 80rpx;
        height: 80rpx;
        margin-bottom: 6rpx;
        font-size: 40rpx;
        border: 1rpx solid #444;
        border-radius: 50%;
      }
    }

    .icon-weixin::before {
      border-color: #06c05f;
      color: #06c05f;
    }
  }
}

.tips {
  position: absolute;
  bottom: 80rpx;
  left: 20rpx;
  right: 20rpx;
  font-size: 22rpx;
  color: #999;
  text-align: center;
}
</style>
